[INFO] cloning repository https://github.com/BedrockStreaming/dynamock-http-server
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/BedrockStreaming/dynamock-http-server" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBedrockStreaming%2Fdynamock-http-server", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBedrockStreaming%2Fdynamock-http-server'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 0a9e3a1532cce93464f484360e17bb2b4763c438
[INFO] testing BedrockStreaming/dynamock-http-server against try#b8e88e5ddf5521a9f43ee3f62a702388c713e4bb for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBedrockStreaming%2Fdynamock-http-server" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-5-tc2/source/rust-toolchain.toml
[INFO] started tweaking git repo https://github.com/BedrockStreaming/dynamock-http-server
[INFO] removed 0 missing tests
[INFO] finished tweaking git repo https://github.com/BedrockStreaming/dynamock-http-server
[INFO] tweaked toml for git repo https://github.com/BedrockStreaming/dynamock-http-server written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/BedrockStreaming/dynamock-http-server on toolchain b8e88e5ddf5521a9f43ee3f62a702388c713e4bb
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/BedrockStreaming/dynamock-http-server already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9739edeefe7539e71d92f7dab26533d3b54152e9fac54865d8c11b6e69925759
[INFO] running `Command { std: "docker" "start" "-a" "9739edeefe7539e71d92f7dab26533d3b54152e9fac54865d8c11b6e69925759", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9739edeefe7539e71d92f7dab26533d3b54152e9fac54865d8c11b6e69925759", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9739edeefe7539e71d92f7dab26533d3b54152e9fac54865d8c11b6e69925759", kill_on_drop: false }`
[INFO] [stdout] 9739edeefe7539e71d92f7dab26533d3b54152e9fac54865d8c11b6e69925759
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] df964cef6333d030ce714dec90df45ec3f05594a3fdc253226adbb8d6406bf58
[INFO] running `Command { std: "docker" "start" "-a" "df964cef6333d030ce714dec90df45ec3f05594a3fdc253226adbb8d6406bf58", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.69
[INFO] [stderr]    Compiling bytes v1.5.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]    Compiling tracing-core v0.1.32
[INFO] [stderr]    Compiling futures-task v0.3.29
[INFO] [stderr]    Compiling serde v1.0.190
[INFO] [stderr]    Compiling futures-util v0.3.29
[INFO] [stderr]    Compiling futures-channel v0.3.29
[INFO] [stderr]    Compiling futures-sink v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.74
[INFO] [stderr]    Compiling socket2 v0.5.5
[INFO] [stderr]    Compiling signal-hook-registry v1.4.1
[INFO] [stderr]    Compiling mio v0.8.9
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling serde_json v1.0.107
[INFO] [stderr]    Compiling utf8parse v0.2.1
[INFO] [stderr]    Compiling anstyle-parse v0.2.2
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling colorchoice v1.0.0
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling anstyle-query v1.0.0
[INFO] [stderr]    Compiling indexmap v2.11.1
[INFO] [stderr]    Compiling http v0.2.9
[INFO] [stderr]    Compiling http v1.3.1
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]    Compiling socket2 v0.4.10
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling tracing-log v0.1.4
[INFO] [stderr]    Compiling thread_local v1.1.7
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]    Compiling tracing-subscriber v0.3.17
[INFO] [stderr]    Compiling clap_builder v4.5.47
[INFO] [stderr]    Compiling syn v2.0.38
[INFO] [stderr]    Compiling http-body v0.4.5
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling tokio-macros v2.1.0
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling serde_derive v1.0.190
[INFO] [stderr]    Compiling pin-project-internal v1.1.3
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling tokio v1.33.0
[INFO] [stderr]    Compiling pin-project v1.1.3
[INFO] [stderr]    Compiling tracing v0.1.40
[INFO] [stderr]    Compiling clap v4.5.47
[INFO] [stderr]    Compiling tokio-util v0.7.10
[INFO] [stderr]    Compiling hyper v0.14.27
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling serde_path_to_error v0.1.14
[INFO] [stderr]    Compiling h2 v0.4.12
[INFO] [stderr]    Compiling serde-jsonlines v0.7.0
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling rusty-dynamock-http-server v0.5.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 33.77s
[INFO] running `Command { std: "docker" "inspect" "df964cef6333d030ce714dec90df45ec3f05594a3fdc253226adbb8d6406bf58", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "df964cef6333d030ce714dec90df45ec3f05594a3fdc253226adbb8d6406bf58", kill_on_drop: false }`
[INFO] [stdout] df964cef6333d030ce714dec90df45ec3f05594a3fdc253226adbb8d6406bf58
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 582dbc96b172b2e52e8cc587cc976488a0f106717af8379df2373f38a06caf5b
[INFO] running `Command { std: "docker" "start" "-a" "582dbc96b172b2e52e8cc587cc976488a0f106717af8379df2373f38a06caf5b", kill_on_drop: false }`
[INFO] [stderr]    Compiling memchr v2.6.4
[INFO] [stderr]    Compiling futures-channel v0.3.29
[INFO] [stderr]    Compiling futures-task v0.3.29
[INFO] [stderr]    Compiling futures-util v0.3.29
[INFO] [stderr]    Compiling futures-io v0.3.29
[INFO] [stderr]    Compiling libc v0.2.149
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling futures-macro v0.3.29
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling serde_json v1.0.107
[INFO] [stderr]    Compiling sealed v0.5.0
[INFO] [stderr]    Compiling rustls v0.22.4
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling terminal_size v0.4.1
[INFO] [stderr]    Compiling bytecount v0.6.7
[INFO] [stderr]    Compiling thiserror v1.0.50
[INFO] [stderr]    Compiling peg-runtime v0.6.3
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling rustls-pki-types v1.12.0
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling clap_builder v4.5.47
[INFO] [stderr]    Compiling thiserror-impl v1.0.50
[INFO] [stderr]    Compiling typed-builder-macro v0.15.2
[INFO] [stderr]    Compiling hyper v1.7.0
[INFO] [stderr]    Compiling walkdir v2.4.0
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]    Compiling smawk v0.3.2
[INFO] [stderr]    Compiling synthez-core v0.3.1
[INFO] [stderr]    Compiling textwrap v0.16.0
[INFO] [stderr]    Compiling aho-corasick v1.1.2
[INFO] [stderr]    Compiling bstr v1.7.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling peg-macros v0.6.3
[INFO] [stderr]    Compiling webpki-roots v1.0.2
[INFO] [stderr]    Compiling itertools v0.11.0
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]    Compiling escargot v0.5.8
[INFO] [stderr]    Compiling inflections v1.1.1
[INFO] [stderr]    Compiling typed-builder v0.15.2
[INFO] [stderr]    Compiling url v2.4.1
[INFO] [stderr]    Compiling regex-automata v0.4.3
[INFO] [stderr]    Compiling synthez-codegen v0.3.1
[INFO] [stderr]    Compiling webpki-roots v0.26.11
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling gherkin v0.14.0
[INFO] [stderr]    Compiling clap v4.5.47
[INFO] [stderr]    Compiling console v0.15.7
[INFO] [stderr]    Compiling synthez v0.3.1
[INFO] [stderr]    Compiling nom_locate v4.2.0
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling smart-default v0.7.1
[INFO] [stderr]    Compiling inventory v0.3.12
[INFO] [stderr]    Compiling drain_filter_polyfill v0.1.3
[INFO] [stderr]    Compiling ipnet v2.9.0
[INFO] [stderr]    Compiling peg v0.6.3
[INFO] [stderr]    Compiling json_value_merge v2.0.0
[INFO] [stderr]    Compiling ring v0.17.5
[INFO] [stderr]    Compiling tower v0.4.13
[INFO] [stderr]    Compiling hyper v0.14.27
[INFO] [stderr]    Compiling futures-executor v0.3.29
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling futures v0.3.29
[INFO] [stderr]    Compiling hyper-util v0.1.7
[INFO] [stderr]    Compiling regex v1.10.2
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]    Compiling globset v0.4.13
[INFO] [stderr]    Compiling cucumber-expressions v0.3.0
[INFO] [stderr]    Compiling ignore v0.4.20
[INFO] [stderr]    Compiling lazy-regex-proc_macros v3.0.1
[INFO] [stderr]    Compiling globwalk v0.8.1
[INFO] [stderr]    Compiling lazy-regex v3.0.2
[INFO] [stderr]    Compiling cucumber-codegen v0.20.1
[INFO] [stderr]    Compiling rustls-webpki v0.102.8
[INFO] [stderr]    Compiling cucumber v0.20.1
[INFO] [stderr]    Compiling tokio-rustls v0.25.0
[INFO] [stderr]    Compiling hyper-rustls v0.26.0
[INFO] [stderr]    Compiling reqwest v0.12.4
[INFO] [stderr]    Compiling rusty-dynamock-http-server v0.5.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 28.74s
[INFO] running `Command { std: "docker" "inspect" "582dbc96b172b2e52e8cc587cc976488a0f106717af8379df2373f38a06caf5b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "582dbc96b172b2e52e8cc587cc976488a0f106717af8379df2373f38a06caf5b", kill_on_drop: false }`
[INFO] [stdout] 582dbc96b172b2e52e8cc587cc976488a0f106717af8379df2373f38a06caf5b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b8e88e5ddf5521a9f43ee3f62a702388c713e4bb" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 9e44d9031a24cc9354188fe56c3e009c892168687286a06ba771315297d1415d
[INFO] running `Command { std: "docker" "start" "-a" "9e44d9031a24cc9354188fe56c3e009c892168687286a06ba771315297d1415d", kill_on_drop: false }`
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/main-eaa0fd3456293a9c)
[INFO] [stdout] 
[INFO] [stdout] running 17 tests
[INFO] [stdout] test domain::request::tests::it_fails_to_match_a_request_with_query ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_match_a_request_with_headers ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_match_a_simple_request_with_a_json_body ... ok
[INFO] [stdout] test domain::request::tests::it_includes_hashmap ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_match_a_simple_request_on_path ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_match_a_simple_request_on_method ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_includes_hashmap ... ok
[INFO] [stdout] test domain::request::tests::it_includes_hashmap_empty_inner ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_simple_request_with_a_json_body ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_simple_request_with_extra_headers ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_simple_request_with_an_extra_json_body ... ok
[INFO] [stdout] test domain::request::tests::it_includes_hashmap_no_inner ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_request_with_headers ... ok
[INFO] [stdout] test domain::request::tests::it_fails_to_includes_hashmap_no_outer ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_simple_request ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_request_with_query ... ok
[INFO] [stdout] test domain::request::tests::it_matches_a_simple_request_with_extra_query ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 17 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/cucumber.rs (/opt/rustwide/target/debug/deps/cucumber-828d3d77c45d0b54)
[INFO] [stdout] Feature: We can add a mock and query it
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:52.633949Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:52.634585Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:52.634815Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | GET                       |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:52.740126Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called GET /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling GET "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:52.923585Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:52.923965Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:52.924121Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | POST                      |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:53.030497Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called POST /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling POST "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:53.223716Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:53.224143Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:53.224362Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | PUT                       |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:53.328564Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called PUT /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling PUT "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:53.531934Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:53.532267Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:53.532386Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | DELETE                    |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:53.637677Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called DELETE /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling DELETE "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:53.852152Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:53.852499Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:53.852693Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | OPTIONS                   |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:53.960924Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called OPTIONS /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling OPTIONS "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario Outline: with a simple mock, and query it
[INFO] [stdout] [2m2026-05-03T21:58:54.163147Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:54.163516Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:54.163615Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | PATCH                     |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:54.267457Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called PATCH /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling PATCH "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout]   Scenario: try more complex assertions on body
[INFO] [stdout] [2m2026-05-03T21:58:54.481655Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:54.482287Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:54.482643Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | GET                                               |
[INFO] [stdout]        | /request/path   | /request                                          |
[INFO] [stdout]        | /response/body  | !json {"some": {"sub": "content"}, "raw": "item"} |
[INFO] [stdout] [2m2026-05-03T21:58:54.585752Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called GET /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout]    ✔  When calling GET "/request"
[INFO] [stdout]    ✔  Then response contains:
[INFO] [stdout]        | /some | !json {"sub": "content"} |
[INFO] [stdout]        | /raw  | item                     |
[INFO] [stdout]   Scenario: Finite mock calling
[INFO] [stdout] [2m2026-05-03T21:58:54.776300Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:54.776603Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:54.776702Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | GET                       |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]        | /usage_count    | !int 1                    |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:54.879558Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called GET /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  Then calling GET "/request" should be ok
[INFO] [stdout] [2m2026-05-03T21:58:54.881069Z[0m [33m WARN[0m [2mmain::application::action::mock[0m[2m:[0m Request 'All responses are exhausted' not found
[INFO] [stdout]    ✔  Then calling GET "/request" should fail
[INFO] [stdout]   Scenario: Multiple mock calling on the same request
[INFO] [stdout] [2m2026-05-03T21:58:55.083041Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:55.083349Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:55.083466Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | GET                       |
[INFO] [stdout]        | /request/path   | /request                  |
[INFO] [stdout]        | /response/body  | !json {"some": "content"} |
[INFO] [stdout]        | /usage_count    | !int 1                    |
[INFO] [stdout]    ✔  Given a mock with:
[INFO] [stdout]        | /request/method | GET                        |
[INFO] [stdout]        | /request/path   | /request                   |
[INFO] [stdout]        | /response/body  | !json {"some": "content2"} |
[INFO] [stdout]        | /usage_count    | !int 1                     |
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout] [2m2026-05-03T21:58:55.218032Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called GET /request, responding HTTP 200 OK
[INFO] [stdout] [2m2026-05-03T21:58:55.219112Z[0m [32m INFO[0m [2mmain::application::action::mock[0m[2m:[0m Called GET /request, responding HTTP 200 OK
[INFO] [stdout]    ✔  When calling GET "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content"
[INFO] [stdout] [2m2026-05-03T21:58:55.220717Z[0m [33m WARN[0m [2mmain::application::action::mock[0m[2m:[0m Request 'All responses are exhausted' not found
[INFO] [stdout]    ✔  When calling GET "/request"
[INFO] [stdout]    ✔  Then response item "/some" should be "content2"
[INFO] [stdout]    ✔  Then calling GET "/request" should fail
[INFO] [stdout] Feature: Dynamock admin can list configured mocks
[INFO] [stdout]   Scenario: with a simple mock
[INFO] [stdout] [2m2026-05-03T21:58:55.424353Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:55.424727Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:55.424903Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given default mock
[INFO] [stdout]    ✔  Then mock list has 1 item
[INFO] [stdout]   Scenario: mock list contains request data
[INFO] [stdout] [2m2026-05-03T21:58:55.724421Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:55.724793Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:55.724966Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given default mock
[INFO] [stdout]    ✔  When getting mocks list
[INFO] [stdout]    ✔  Then response item "/0/request/method" should be "GET"
[INFO] [stdout] Feature: Mocks can be reset
[INFO] [stdout]   Scenario: resetting mocks does reset the list
[INFO] [stdout] [2m2026-05-03T21:58:56.023046Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Preloaded 0 mocks
[INFO] [stdout] [2m2026-05-03T21:58:56.023399Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [admin] Listening on 0.0.0.0:3000
[INFO] [stdout] [2m2026-05-03T21:58:56.023506Z[0m [32m INFO[0m [2mmain[0m[2m:[0m [mock] Listening on 0.0.0.0:3001
[INFO] [stdout]    ✔  Given default mock
[INFO] [stdout]    ✔  When resetting mocks
[INFO] [stdout]    ✔  Then mock list has 0 item
[INFO] [stdout] [Summary]
[INFO] [stdout] 3 features
[INFO] [stdout] 12 scenarios (12 passed)
[INFO] [stdout] 48 steps (48 passed)
[INFO] running `Command { std: "docker" "inspect" "9e44d9031a24cc9354188fe56c3e009c892168687286a06ba771315297d1415d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9e44d9031a24cc9354188fe56c3e009c892168687286a06ba771315297d1415d", kill_on_drop: false }`
[INFO] [stdout] 9e44d9031a24cc9354188fe56c3e009c892168687286a06ba771315297d1415d
